<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>let</title>
</head>
<body>
    <div class="container">
        <h2>点击切换颜色</h2><br>
        <div class="item"></div>
        <div class="item"></div>
        <div class="item"></div>
    </div>
</body>

<script type="text/javascript">

//变量声明
let a;
let b,c,d;
let e = 100; 
let f = "你好！";

//特性1 无法重复声明变量
let star = "罗志祥";
// let satr = "小猪";//报错

//特性2 块级作用域 
{
    let girl = "周扬青";
}
// console.log("girl:"+ girl);//报错

//特性3 不存在变量提升（无法给变量赋予初始值）
console.log(song);
var song='恋爱达人';
//let song='恋爱达人';//报错

//特性4 不影响作用域链
{
    let school = '北大';
    function fn(){
        console.log(school);
    };
    fn();//运行正常
}


//实践操作
let items = document.getElementsByClassName('item');

// for(var i=0;i<items.length;i++){
//     items[i].onclick = function(){
//         this.style.background = 'pink';//这里因为var污染变量i;导致最终值i始终为3，因此，无法使用items[i]实现这个功能。
//     };
// }

for(let i=0;i<items.length;i++){
    items[i].onclick = function(){
        items[i].style.background = 'pink';
    };
}

</script>


<style>
    .container{
        display: flex;
    }
    .item{
        width: 300px;
        height: 200px;
        margin: 10px;
        border:1px saddlebrown solid;
    }
</style>
</html>